<template>
  <t-layout-page>
    <t-layout-page-item>
      <t-table
        title="操作列"
        ref="selectionTable"
        :table="table"
        :btnPermissions="['operator-view-detail', 'operator-edit']"
        :columns="table.columns"
        @selection-change="selectionChange"
        :isShowPagination="false"
      >
        <template #toolbar>
          <el-button size="default" type="primary" :disabled="ids.length < 1" @click="cancelSelect"
            >取消选中</el-button
          >
          <el-button size="default" type="primary" @click="add">新增</el-button>
          <el-button size="default" type="danger" :disabled="ids.length < 1" @click="del"
            >删除</el-button
          >
        </template>
      </t-table>
    </t-layout-page-item>
  </t-layout-page>
</template>

<script setup lang="tsx">
import { reactive, ref } from "vue"
const viewDetail = val => {
  console.log("viewDetail", val)
}
const edit = val => {
  console.log("edit", val)
}
const nullify = val => {
  console.log("nullify", val)
}
// 获取ref
const selectionTable = ref<any>(null)
let table = reactive<TableTypes.Table>({
  firstColumn: { type: "selection", fixed: true },
  // 接口返回数据
  data: [
    {
      id: "1",
      date: "2019-09-25",
      date1: "2019-09-26",
      name: "张三",
      status: "2",
      address: "广东省广州市天河区"
    },
    {
      id: "2",
      date: "2019-09-26",
      date1: "2019-09-27",
      name: "张三1",
      status: "1",
      address: "广东省广州市天广东省广州市天河区2广东省广州市天河区2河区2"
    },
    {
      id: "3",
      date: "2019-09-26",
      date1: "2019-09-28",
      name: "张三1",
      status: "1",
      address: "广东省广州市天广东省广州市天河区2广东省广州市天河区2河区2"
    },
    {
      id: "4",
      date: "2019-09-26",
      date1: "2019-09-29",
      name: "张三1",
      status: "1",
      address: "广东省广州市天广东省广州市天河区2广东省广州市天河区2河区2"
    }
  ],
  // 表头数据
  columns: [
    { prop: "name", label: "姓名", width: "120" },
    { prop: "date", label: "日期", width: "180" },
    {
      prop: "status",
      label: "状态",
      width: "100"
    },
    { prop: "date1", label: "日期22", width: "180" },
    {
      prop: "address",
      label: "地址",
      width: "220"
    }
  ],
  // 表格内操作列
  operator: [
    {
      text: "查看",
      fun: viewDetail,
      hasPermi: "operator-view-detail",
      noshow: [{ key: "status", val: ["1"] }]
    },
    {
      text: "编辑",
      hasPermi: "operator-edit",
      fun: edit
    },
    {
      text: "作废",
      fun: nullify
    }
  ],
  // 操作列样式
  operatorConfig: {
    fixed: "right", // 固定列表右边（left则固定在左边）
    width: 200,
    label: "操作"
  }
})
const ids = ref([])
// 选择复选框
const selectionChange = (val: any) => {
  console.log("选择复选框", val)
  ids.value = val
}
// 取消选中
const cancelSelect = () => {
  console.log("取消选中", selectionTable.value)
  if (ids.value.length > 0) {
    console.log("取消选中222", selectionTable.value)
    selectionTable.value.clearSelection()
  }
}
// 新增按钮
const add = () => {
  console.log("add按钮")
  table.data.push({
    id: "3",
    date: "2019-09-26",
    date1: "2019-09-28",
    name: "push新增",
    status: "1",
    address: "广东省广州市天广东省广州市天河区2广东省广州市天河区2河区2"
  })
}
// 删除按钮
const del = () => {
  console.log("del按钮")
}
</script>
